[INFO] cloning repository https://github.com/krummelur/rust-pong
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/krummelur/rust-pong" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkrummelur%2Frust-pong", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkrummelur%2Frust-pong'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 25e20c1dca004dd6ad3e41dccb1386cdf4a344af
[INFO] checking krummelur/rust-pong against master#cced03bfd61a304243a34504618ecec86c17063f for pr-157082
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkrummelur%2Frust-pong" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/krummelur/rust-pong
[INFO] finished tweaking git repo https://github.com/krummelur/rust-pong
[INFO] tweaked toml for git repo https://github.com/krummelur/rust-pong written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/krummelur/rust-pong on toolchain cced03bfd61a304243a34504618ecec86c17063f
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cced03bfd61a304243a34504618ecec86c17063f" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/krummelur/rust-pong already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cced03bfd61a304243a34504618ecec86c17063f" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: Cargo.toml: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] [stderr] warning: `rust-example` (manifest) generated 1 warning
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded sdl2 v0.32.2
[INFO] [stderr]   Downloaded sdl2-sys v0.32.6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-m" "1610612736" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3e793bdf10248eb2ddbd6b0faebed8155c11b4589982e2893733958d93e8d540" "sleep" "infinity", kill_on_drop: false }`
[INFO] [stdout] 4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571
[INFO] running `Command { std: "docker" "start" "4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-w" "/opt/rustwide/workdir" "--user" "0:0" "4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571" "/opt/rustwide/cargo-home/bin/cargo" "+cced03bfd61a304243a34504618ecec86c17063f" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-w" "/opt/rustwide/workdir" "--user" "0:0" "4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571" "/opt/rustwide/cargo-home/bin/cargo" "+cced03bfd61a304243a34504618ecec86c17063f" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stderr] warning: Cargo.toml: `package.edition` is unspecified, defaulting to `2015` while the latest is `2024`
[INFO] [stderr] warning: `rust-example` (manifest) generated 1 warning
[INFO] [stderr]    Compiling autocfg v0.1.4
[INFO] [stderr]    Compiling libc v0.2.58
[INFO] [stderr]     Checking spin v0.5.0
[INFO] [stderr]    Compiling cfg-if v0.1.9
[INFO] [stderr]    Compiling sdl2 v0.32.2
[INFO] [stderr]     Checking rand_jitter v0.1.4
[INFO] [stderr]    Compiling sdl2-sys v0.32.6
[INFO] [stderr]     Checking lazy_static v1.3.0
[INFO] [stderr]     Checking c2-chacha v0.2.2
[INFO] [stderr]    Compiling num-traits v0.2.8
[INFO] [stderr]    Compiling num-integer v0.1.41
[INFO] [stderr]    Compiling rand_pcg v0.1.2
[INFO] [stderr]    Compiling num-iter v0.1.39
[INFO] [stderr]    Compiling rand_chacha v0.1.1
[INFO] [stderr]    Compiling rand_chacha v0.2.0
[INFO] [stderr]    Compiling rand v0.6.5
[INFO] [stderr]     Checking getrandom v0.1.6
[INFO] [stderr]     Checking rand_os v0.1.3
[INFO] [stderr]     Checking rand_core v0.5.0
[INFO] [stderr]     Checking rand v0.7.0
[INFO] [stderr]     Checking num v0.1.42
[INFO] [stderr]     Checking rust-example v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]  --> src/client/../protocol.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout]   |                            ^   ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]   |
[INFO] [stdout] 3 - const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout] 3 + const MESSAGE_LEN: usize = 9*4 ;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused label
[INFO] [stdout]   --> src/client/main.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     'running: loop {
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_labels)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]  --> src/server/../protocol.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout]   |                            ^   ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]   |
[INFO] [stdout] 3 - const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout] 3 + const MESSAGE_LEN: usize = 9*4 ;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]  --> src/client/../protocol.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout]   |                            ^   ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]   |
[INFO] [stdout] 3 - const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout] 3 + const MESSAGE_LEN: usize = 9*4 ;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused label
[INFO] [stdout]   --> src/client/main.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     'running: loop {
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_labels)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]  --> src/server/../protocol.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout]   |                            ^   ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]   |
[INFO] [stdout] 3 - const MESSAGE_LEN: usize = (9*4);
[INFO] [stdout] 3 + const MESSAGE_LEN: usize = 9*4 ;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `reset` are never used
[INFO] [stdout]   --> src/client/../protocol.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl GameState {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 14 |     /// Returns a reference to a new GameState instance with default values 
[INFO] [stdout] 15 |     pub fn new() -> GameState {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub fn reset(&mut self) -> () {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/client/../protocol.rs:57:8
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub fn serialize(game_state: GameState, player_index: i32) -> [u8; MESSAGE_LEN] {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_colliding` is never used
[INFO] [stdout]   --> src/client/../game_objects.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn is_colliding(obj1_pos: [i32;2], obj2_pos: [i32;2], obj1_dim: [u32;2], obj2_dim: [u32;2]) -> (bool, f32) {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `remoteAddress` should have a snake case name
[INFO] [stdout]   --> src/client/main.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 |     let remoteAddress = &args[args.len()-1];
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `remote_address`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `reset` are never used
[INFO] [stdout]   --> src/client/../protocol.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl GameState {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 14 |     /// Returns a reference to a new GameState instance with default values 
[INFO] [stdout] 15 |     pub fn new() -> GameState {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub fn reset(&mut self) -> () {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `serialize` is never used
[INFO] [stdout]   --> src/client/../protocol.rs:57:8
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub fn serialize(game_state: GameState, player_index: i32) -> [u8; MESSAGE_LEN] {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_colliding` is never used
[INFO] [stdout]   --> src/client/../game_objects.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn is_colliding(obj1_pos: [i32;2], obj2_pos: [i32;2], obj1_dim: [u32;2], obj2_dim: [u32;2]) -> (bool, f32) {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `remoteAddress` should have a snake case name
[INFO] [stdout]   --> src/client/main.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 |     let remoteAddress = &args[args.len()-1];
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `remote_address`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayerBase` is never constructed
[INFO] [stdout]   --> src/server/../game_objects.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct PlayerBase {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_y_position`, `set_x_position`, and `draw` are never used
[INFO] [stdout]   --> src/server/../game_objects.rs:50:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | impl PlayerBase {
[INFO] [stdout]    | --------------- associated items in this implementation
[INFO] [stdout] 49 |     /// Returns a new PlayerBase instance
[INFO] [stdout] 50 |     pub fn new() -> PlayerBase {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn set_y_position(&mut self, new_position: i32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn set_x_position(&mut self, new_position: i32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 72 |     pub fn draw(self, renderer: &mut WindowCanvas) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ball` is never constructed
[INFO] [stdout]   --> src/server/../game_objects.rs:79:12
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub struct Ball {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_position`, and `draw` are never used
[INFO] [stdout]    --> src/server/../game_objects.rs:85:12
[INFO] [stdout]     |
[INFO] [stdout]  83 | impl Ball {
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout]  84 |     /// Returns a new Ball instance
[INFO] [stdout]  85 |     pub fn new() -> Ball {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub fn set_position(&mut self, new_position: [i32;2]) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn draw(self, renderer: &mut WindowCanvas) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LocalPlayer` is never constructed
[INFO] [stdout]    --> src/server/../game_objects.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct LocalPlayer {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `handle_input` are never used
[INFO] [stdout]    --> src/server/../game_objects.rs:118:12
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl LocalPlayer {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 117 |     /// Returns a new LocalPlayer reference
[INFO] [stdout] 118 |     pub fn new(ev_pump: sdl2::EventPump) -> LocalPlayer {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn handle_input(&mut self) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RemotePlayer` is never constructed
[INFO] [stdout]    --> src/server/../game_objects.rs:131:12
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub struct RemotePlayer {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/server/../game_objects.rs:137:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | impl RemotePlayer {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 136 |     /// Returns a new RemotePlayer instance
[INFO] [stdout] 137 |     pub fn new() -> RemotePlayer {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputHandler` is never constructed
[INFO] [stdout]    --> src/server/../game_objects.rs:144:8
[INFO] [stdout]     |
[INFO] [stdout] 144 | struct InputHandler {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `handle_input` are never used
[INFO] [stdout]    --> src/server/../game_objects.rs:149:8
[INFO] [stdout]     |
[INFO] [stdout] 148 | impl InputHandler {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout] 149 |     fn new(ev_pump: sdl2::EventPump) -> InputHandler {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     fn handle_input(&mut self) -> i32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/server/../protocol.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn deserialize(message: [u8; MESSAGE_LEN]) -> GameState {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PlayerBase` is never constructed
[INFO] [stdout]   --> src/server/../game_objects.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct PlayerBase {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_y_position`, `set_x_position`, and `draw` are never used
[INFO] [stdout]   --> src/server/../game_objects.rs:50:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | impl PlayerBase {
[INFO] [stdout]    | --------------- associated items in this implementation
[INFO] [stdout] 49 |     /// Returns a new PlayerBase instance
[INFO] [stdout] 50 |     pub fn new() -> PlayerBase {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn set_y_position(&mut self, new_position: i32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn set_x_position(&mut self, new_position: i32) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 72 |     pub fn draw(self, renderer: &mut WindowCanvas) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ball` is never constructed
[INFO] [stdout]   --> src/server/../game_objects.rs:79:12
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub struct Ball {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_position`, and `draw` are never used
[INFO] [stdout]    --> src/server/../game_objects.rs:85:12
[INFO] [stdout]     |
[INFO] [stdout]  83 | impl Ball {
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout]  84 |     /// Returns a new Ball instance
[INFO] [stdout]  85 |     pub fn new() -> Ball {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub fn set_position(&mut self, new_position: [i32;2]) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn draw(self, renderer: &mut WindowCanvas) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LocalPlayer` is never constructed
[INFO] [stdout]    --> src/server/../game_objects.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct LocalPlayer {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `handle_input` are never used
[INFO] [stdout]    --> src/server/../game_objects.rs:118:12
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl LocalPlayer {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 117 |     /// Returns a new LocalPlayer reference
[INFO] [stdout] 118 |     pub fn new(ev_pump: sdl2::EventPump) -> LocalPlayer {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn handle_input(&mut self) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RemotePlayer` is never constructed
[INFO] [stdout]    --> src/server/../game_objects.rs:131:12
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub struct RemotePlayer {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/server/../game_objects.rs:137:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | impl RemotePlayer {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 136 |     /// Returns a new RemotePlayer instance
[INFO] [stdout] 137 |     pub fn new() -> RemotePlayer {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `InputHandler` is never constructed
[INFO] [stdout]    --> src/server/../game_objects.rs:144:8
[INFO] [stdout]     |
[INFO] [stdout] 144 | struct InputHandler {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `handle_input` are never used
[INFO] [stdout]    --> src/server/../game_objects.rs:149:8
[INFO] [stdout]     |
[INFO] [stdout] 148 | impl InputHandler {
[INFO] [stdout]     | ----------------- associated items in this implementation
[INFO] [stdout] 149 |     fn new(ev_pump: sdl2::EventPump) -> InputHandler {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     fn handle_input(&mut self) -> i32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `deserialize` is never used
[INFO] [stdout]   --> src/server/../protocol.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn deserialize(message: [u8; MESSAGE_LEN]) -> GameState {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 5.17s
[INFO] running `Command { std: "docker" "inspect" "4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571", kill_on_drop: false }`
[INFO] [stdout] 4d2b5d114539f0e9fab32124939a32d7d2e05418d7e071d7e1ce3d880b96d571
